"""
125. 验证回文串
简单
相关标签
相关企业
如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后，短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。

字母和数字都属于字母数字字符。

给你一个字符串 s，如果它是 回文串 ，返回 true ；否则，返回 false 。



示例 1：

输入: s = "A man, a plan, a canal: Panama"
输出：true
解释："amanaplanacanalpanama" 是回文串。
示例 2：

输入：s = "race a car"
输出：false
解释："raceacar" 不是回文串。
示例 3：

输入：s = " "
输出：true
解释：在移除非字母数字字符之后，s 是一个空字符串 "" 。
由于空字符串正着反着读都一样，所以是回文串。


提示：

1 <= s.length <= 2 * 105
s 仅由可打印的 ASCII 字符组成
"""
class Solution:
    def isPalindrome(self, s: str) -> bool:
        # for item in s:
        #     if not item.isalnum():
        #         s=s.replace(item,'')
        # print(s.lower())
        # if s.lower()==s[::-1].lower():
        #     return True
        # return False
        """
        简便写法,使用列推表达式 [expression for item in iterable if condition]
        """
        a= ''.join(item for item in s if item.isalnum()).lower()
        return a==a[::-1]
if __name__ == '__main__':
    print(Solution().isPalindrome("A man, a plan, a canal: Panama"))